home *** CD-ROM | disk | FTP | other *** search
/ Robotics & Artificial Int…3 (Professional Edition) / Robotics & Artificial Intelligence Tools 2003 (Professional Edition).iso / neural network tool and application / nsinstall.exe / data1.cab / DLLCust_Files / NOISE / DECUNIFM.C < prev    next >
Encoding:
C/C++ Source or Header  |  2002-03-08  |  1.6 KB  |  49 lines

  1. // Dynamic link library implementation of NeuroSolutions Noise component for Uniform setting
  2.  
  3. #include "NSDLL.h" 
  4.  
  5. /***************************/
  6. /* Activation of component */
  7. __declspec(dllexport) NSFloat performNoise(
  8.     DLLData    *instance,    // Pointer to instance data (may be NULL)
  9.     NSFloat    variance,     // Variance set within components inspector
  10.     NSFloat    mean         // Mean set within components inspector
  11.     )
  12. {
  13.     NSFloat decay = getFloatParameter(instance, 2, 1);
  14.     NSFloat *varianceDecay = getUserData(instance);
  15.     NSFloat noise = ((NSFloat)sqrt(3*variance * *varianceDecay)*(NSFloat)(((NSFloat)rand()/RAND_MAX)-0.5)+mean);
  16.     *varianceDecay *= decay;
  17.     return noise;
  18. }
  19.  
  20. /**********************************************************************/
  21. /* Called before any performNoise calls, allowing any initialization. */
  22. __declspec(dllexport) void getReadyToFire(
  23.     DLLData    *instance    // Pointer to instance data (may be NULL) 
  24.     )
  25. {
  26.     NSFloat *varianceDecay = getUserData(instance);
  27.     *varianceDecay = 1.0f;
  28. }
  29.  
  30. /******************************************/
  31. /* Management of instance data (OPTIONAL) */
  32. __declspec(dllexport) DLLData *allocNoise(
  33.     DLLData    *oldInstance    // Pointer to the last instance if reallocating 
  34.     )
  35. {
  36.     DLLData *instance = allocDLLInstance(oldInstance);
  37.     setParameterName(instance, 2, 1, "Decay", FALSE);
  38.     setFloatParameter(instance, 2, 1, 0.9f, FALSE);
  39.     setUserData(instance, malloc(sizeof(NSFloat)));
  40.     return instance;
  41. }
  42.  
  43. __declspec(dllexport) void freeNoise(DLLData *instance)
  44. {
  45.     if (getUserData(instance))
  46.         free(getUserData(instance));
  47.     freeDLLInstance(instance);
  48. }
  49.